// pages/shoplist/shoplist.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    query:{},//页面参数接收传过来的参数
    shopList:[], //用来存放所有请求的数据
    page:1,//默认请求第一页的数据信息
    pageSize:10,//,默认一页请求十条数据
    total:0, //总数据
    isloading:false //设置一个节流阀 默认false
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    //接收传过来的参数
    this.setData({
      //赋值给query
      query:options
    }),
    this.getShopList()
  },
  //请求分页数据
  getShopList(cb){
    //请求数据
    this.setData({
      isloading:true
    })
    //显示loading效果
    wx.showLoading({
      title: '数据加载中...',
    })
    // console.log(this.data.query.id);
    wx.request({
      url: `https://www.escook.cn/categories/${this.data.query.id-0}/shops`,
      method:"GET",
      data:{
        _page:this.data.page,
        _limit:this.data.pageSize
      },
      success:(res)=>{
        // console.log(res);
        this.setData({
          shopList:[...this.data.shopList,...res.data],
          total:res.header['X-Total-Count'] - 0
        })
      },
      //完成时隐藏loading效果
      complete:()=>{
        //隐藏loading效果
        wx.hideLoading()
        //请求完成之后
        this.setData({
          isloading:false
        })
        //刷新完成关闭刷新页
        // wx.stopPullDownRefresh()
        cb && cb()

      }
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {
    //动态设置标题名
    wx.setNavigationBarTitle({
      title:this.data.query.title
    })
  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    //下拉刷新 重置关键数据
    this.setData({
      page:1,
      shopList:[],
      total:0
    })
    //重新发起数据请求 并传递个回调函数
    this.getShopList(()=>{
      wx.stopPullDownRefresh()
    })
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    //判断是否还有下一条数据
    if(this.data.page*this.data.pageSize >= this.data.total){
      //证明没有下一页的数据了
      return wx.showToast({
        title: '数据加载完毕！',
        icon:"none"
      })
    }
    //节流判断 正在请求就返回
    if(this.data.isloading) return
   this.setData({
    page:this.data.page + 1
   })
   this.getShopList()
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})